<?php

namespace App\Models;

use App\Models\BaseModel;

class Dept extends BaseModel
{

    protected $table = 'dept';

    protected $fillable = [
        'name',
        'code',
        'parentId',
        'sort',
        'status'
    ];

    /**
     * 递归查找当前部门及其所有子部门
     *
     * @param int $deptId
     * @return \Illuminate\Database\Eloquent\Collection
     */
    public static function getAllSubDepts(int $deptId)
    {
        // 获取当前部门
        $dept = Dept::find($deptId);

        // 如果找不到部门，返回空集合
        if (!$dept) {
            return collect();
        }

        // 获取当前部门和它的所有子部门
        return $dept->descendants()->pluck('id')->merge([$dept->id]);
    }

    /**
     * 获取子部门
     *
     * @return \Illuminate\Database\Eloquent\Relations\HasMany
     */
    public function descendants()
    {
        return $this->hasMany(Dept::class, 'parentId', 'id');
    }
}
